AMENDMENT AND RESPONSE UNDER 37 CFR § 1.111 

Serial Number: 10/815,272 
Filing Date: March 31, 2004 

Title: INTEGRATED CIRCUIT CAPABLE OF REMOTE DATA STORAGE 

IN THE CLAIMS 

Please amend the claims as follows: 

1 . (Currently Amended) An apparatus, comprising: 
an integrated circuit (IC) configured to receive capable of receiving an input/output (I/O) 

request to write data stored on at least one target device comprised in at least one local storage 
array and generate , said integrated circuit further capable of generating one or more I/O 
transactions configured to write capable of writing data on at least one target device comprised in 
at least one remote storage array , said IC further comprising a counter configured to include at 
least one bit corresponding to at least one data block transmitted during said one or more I/O 
transactions which was not successfully written to said at least one remote storage array . 

2. (Original) The apparatus of claim 1, wherein: 

said integrated circuit is further capable of generating one or more I/O transactions 
capable of writing data stored on said at least one target device comprised in said at least one 
local storage array. 

3. (Original) The apparatus of claim 1, wherein: 

said local storage array and said remote storage array each comprise a redundant array of 
inexpensive disks (RAID) each comprising RAID Level 1 storage arrays. 

4. (Original) The apparatus of claim 3, wherein: 

said one or more I/O transactions capable of writing data on at least one target device 
comprised in at least one remote storage array comprises a transaction to mirror data on said 
RAID Level 1 storage array in response to said I/O request to write data stored on at least one 
target device comprised in at least one local storage array. 

5. (Original) The apparatus of claim 1, wherein: 

said local storage array and said remote storage array each comprise a redundant array of 
inexpensive disks (RAID) each comprising at least one of RAID Level 0, RAID Level 10 and 
RAID Level IE storage arrays. 
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6. (Original) The apparatus of claim 5, wherein: 

said one or more 170 transactions capable of writing data on at least one target device 
comprised in at least one remote storage array comprises a transaction to stripe data on at least 
one of said RAID Level 0, RAID Level 10 and RAID Level IE storage arrays in response to said 
170 request to write data stored on at least one target device comprised in at least one local 
storage array. 

7. (Original) The apparatus of claim 1, wherein: 

said integrated circuit further capable of receiving an input/output (I/O) request to read 
data on at least one target device comprised in at least one local storage array, said integrated 
circuit further capable of generating one or more I/O transactions capable of reading data on at 
least one target device comprised in at least one remote storage array. 

8. (Currently Amended) A method, comprising: 

receiving an input/output (I/O) request to write data stored on at least one target device 
comprised in at least one local storage array; and 

generating one or more I/O transactions configured to write capable of writing data on at 
least one target device comprised in at least one remote storage array : and 

incrementing at least one bit corresponding to at least one data block transmitted during 
said one or more I/O transactions which was not successfully written to said at least one remote 
storage array . 

9. (Original) The method of claim 8, further comprising: 

generating at least one of said I/O transactions to mirror data on said local storage array 
and said remote storage array. 

10. (Original) The method of claim 8, further comprising: 

generating at least one of said I/O transactions to stripe data on said local storage array 
and said remote storage array. 
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1 1 . (Original) The method of claim 8, further comprising: 

receiving an 170 request to read data on said at least one target device comprised in said 
at least one local storage array; and 

generating one or more I/O transactions capable of reading data on said at least one target 
device comprised in said at least one remote storage array. 

12. (Original) The method of claim 1 1, further comprising: 

determining the status of said remote storage array, and, if said remote storage array is 
incapable of transmitting data in response to said one or more I/O transactions, regenerating said 
one or more I/O transactions to read data to said remote storage array at one or more preselected 
times. 

13. (Original) The method of claim 12, further comprising: 

storing information based on data unread from said remote storage array on said local 
storage array, and, retrieving said information based on data unread from said local storage array. 

14. (Original) The method of claim 8, further comprising: 

determining the status of said remote storage array, and, if said remote storage array is 
incapable of receiving data, regenerating said one or more I/O transactions to write data on said 
remote storage array at one or more preselected times. 

15. (Original) The method of claim 14, further comprising: 

storing information on said local storage array based on unwritten data related to said I/O 
transactions to write data to said remote storage array, and, retrieving said information based on 
unwritten data from said local storage array and writing said unwritten data to said remote 
storage array. 



16. (Original) The method of claim 11, further comprising: copying data from said at 
least one target device comprised in said at least one remote storage array to said at least one 
target device comprised in said local storage array. 
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17. (Currently Amended) A system, comprising: 

a circuit card comprising an integrated circuit (IC) configured to communicate capable of 
communicating in accordance with a plurality of different communication protocols, the circuit 
card configured to be being capable of being coupled to a bus, and said IC further configured to 
receive integrated circuit further capable of receiving an input/output (170) request to write data 
stored on at least one target device comprised in at least one local storage array, said IC further 
configured to generate integrated circuit further capable of generating one or more 170 
transactions configured to write capable of writing data on at least one target device comprised in 
at least one remote storage array wherein said IC further comprises a counter configured to 
include at least one bit corresponding to at least one data block transmitted during said one or 
more 170 transactions which was not successfully written to said at least one remote storage 



18. (Original) The system of claim 17, wherein: 

said integrated circuit is further capable of generating one or more I/O transactions 
capable of writing data stored on said at least one target device comprised in said at least one 
local storage array. 



19. (Original) The system of claim 17, wherein: 

said local storage array and said remote storage array each comprise a redundant array of 
inexpensive disks (RAID) each comprising RAID Level 1 storage arrays. 



20. (Original) The system of claim 19, wherein: 

said one or more I/O transactions capable of writing data on at least one target device 
comprised in at least one remote storage array comprises a transaction to mirror data on said 
RAID Level 1 storage array in response to said I/O request to write data stored on at least one 
target device comprised in at least one local storage array. 



21. 



(Original) The system of claim 17, wherein: 
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said local storage array and said remote storage array each comprise a redundant array of 
inexpensive disks (RAID) each comprising at least one of RAID Level 0, RAID Level 10 and 
RAID Level IE storage arrays. 

22. (Original) The system of claim 21, wherein: 

said one or more I/O transactions capable of writing data on at least one target device 
comprised in at least one remote storage array comprises a transaction to stripe data on at least 
one of said RAID Level 0, RAID Level 10 and RAID Level IE storage arrays in response to said 
I/O request to write data stored on at least one target device comprised in at least one local 
storage array. 

23. (Original) The system of claim 17, wherein: 

said integrated circuit further capable of receiving an input/output (I/O) request to read 
data on at least one target device comprised in at least one local storage array, said integrated 
circuit further capable of generating one or more I/O transactions capable of reading data on at 
least one target device comprised in at least one remote storage array. 

24. (Currently Amended) An article comprising: 

a storage medium having stored thereon instructions that when executed by a machine 
result in the following operations: 

receiving an input/output (I/O) request to write data stored on at least one target device 
comprised in at least one local storage array; and 

generating one or more I/O transactions configured to write capable of writing data on at 
least one target device comprised in at least one remote storage array ; and 

incrementing at least one bit corresponding to at least one data block transmitted during 
said one or more I/O transactions which was not successfully written to said at least one remote 
storage array . 



25. (Original) The article of claim 24, wherein said instructions that when executed by said 
machine result in the following additional operations: 
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generating at least one of said I/O transactions to mirror data on said local storage array 
and said remote storage array. 

26. (Original) The article of claim 24, wherein said instructions that when executed by said 
machine result in the following additional operations: 

generating at least one of said I/O transactions to stripe data on said local storage array 
and said remote storage array. 

27. (Original) The article of claim 24, wherein said instructions that when executed by said 
machine result in the following additional operations: 

receiving an I/O request to read data on said at least one target device comprised in said 
at least one local storage array; and 

generating one or more I/O transactions capable of reading data on said at least one target 
device comprised in said at least one remote storage array. 

28. (Original) The article of claim 27, wherein said instructions that when executed by said 
machine result in the following additional operations: 

determining the status of said remote storage array, and, if said remote storage array is 
incapable of transmitting data in response to said one or more I/O transactions, regenerating said 
one or more I/O transactions to read data to said remote storage array at one or more preselected 
times. 

29. (Original) The article of claim 28, wherein said instructions that when executed by said 
machine result in the following additional operations: 

storing information based on data unread from said remote storage array on said local 
storage array, and, retrieving said information based on data unread from said local storage array. 



30. (Original) The article of claim 24, wherein said instructions that when executed by said 
machine result in the following additional operations: 
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determining the status of said remote storage array, and, if said remote storage array is 
incapable of receiving data, regenerating said one or more I/O transactions to write data on said 
remote storage array at one or more preselected times. 



31. (Original) The article of claim 30, wherein said instructions that when executed by said 
machine result in the following additional operations: 

storing information on said local storage array based on unwritten data related to said 170 
transactions to write data to said remote storage array, and, retrieving said information based on 
unwritten data from said local storage array and writing said unwritten data to said remote 
storage array. 



